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OMTENTAMEN I DATORSYSTEM, VT2017 


Omtentamensdatum: 2017-08-10 


Tentamen består av totalt 10 uppgifter. Del A består av 7 uppgifter och 
Del B av 3 uppgifter. 

Totalt antal poäng: 19p 

Tillåtna hjälpmedel: Inga 

Skrivhänvisningar: - Skriv läsbart och tydligt för att undvika feltolkningar. 

- Motivera dina Svar, ev. tabeller och beräkningar som 
används för att nå svaret ska också finns i lösning. 

- Ofullständigt motiverade svar kan INTE ge poäng 


Betygsskala 


E 

(50-60)% av Totalt antal poäng 

D 

(61-70)% av Totalt antal poäng 

C 

(71 -80)% av Totalt antal poäng 

B 

(81 -90)% av Totalt antal poäng 

A 

(91-100)% av Totalt antal poäng 


LYCKA TILL! 



Del A 


Frågorna 1 till 3 är multiple choice frågor, välj rätt alternativ på multiple 
choice frågorna. Endast ett alternativ är rätt. Fler angivna svar beaktas inte. 

1 . Hur kan man kontrollera om det finns plats att läsa från JTAG-porten? (lp) 

a) Genom att kontrollera i kontrollregistret att bitarna 16-31, WSPACE, är större än noll. 

b) Genom att kontrollera i dataregistret att bit 15, RVALID, är 1 och att bit 16-31, 
RAVAIL, är större än noll. 

c) Genom att kontrollera i dataregistret att bitarna 0-7, DATA, är större än noll. 

2. Vilken instruktion används för att göra ett ovillkorligt hopp i ett program?? 

(lp) 

a) label br 

b) br 

c) if 

3. Serieportens dataregister har ett flertal fält som används för olika syften. Ett av fälten, bit 
9, heter PE. Det är en så kallad paritetsbit, som används för att kontrollera om information 
som först över är korrekt. Man kan antingen ha jämn eller ojämn paritet, men det är något 
som måste bestämmas i förhand. Hur räknar man ut vilket värde en paritetsbit ska ha om 
jämn paritet används? 

a) Genom att räkna antalet ettor och sedan se till att det blir ett udda antal ettor 
tillsammans med paritetsbitcn. 

b) Genom att räkna antalet ettor och sedan se till att det blir ett jämnt antal ettor 


tillsammans med paritetsbiten. 

c) Genom att räkna antalet bitar och skriva svaret i paritetsbiten. (lp) 

4. Konvertera talet 76.5 till binära talbasen. (lp) 

5. Konvertera binära talet 0101000110 till decimal talbasen. (1 p) 

6. Konvertera 7ABCi6 till decimal talbasen. (lp) 

7. Redundant Array of Independent Discs (RAID) är en serie av olika tekniker för att 

utnyttja synergieffekter av flera hårddiskar. (3p) 

a) RAID kan ge två olika typer av synergieffekter, vilka ? 


b) Välj en av de synergieffekter du angett och förklara hur RAID tekniskt åstadkommer 
den. 



Del B 


Flyttal är ett sätt att representera stora, små och rationella tal. I nedanstående uppgift 
används standarden IEEE 754 för 16-bitars flyttal. Se bilden nedan om flyttals binärt 
lagring. 
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Beräkna operation A+B. Svara med ett 16-bitars binär flyttal enligt bilden ovan 
och IEEE 754. 

Flyttal A : 0 11110 1110001000 

Flyttal B: 0 11011 0011101100 (3p) 

Formeln för att få ut det decimala värdet v ur ett flyttal: 

v=( - 1)t e ckenbi, x 2 expo„en.-15 x (] , mantissa ) 2 


OBS: ofullständigt svar kan INTE ge poäng dvs tabeller och beräkningar som 
används för att nå svaret ska också finns i lösningen. 

2 X En av processorns beståndsdelar är registren. Processorns register kan separeras i två 
kategorier; generalpurpose samt kontrollregister. (3p) 

a) Vad är skillnaden mellan general purpose och kontrollregister? 

b) Förklara syftet som följande kontrollregister har : Program Counter (PC) samt 
Instruction Register (IR). 

3, I ett datorsystem behövs flera typer av minne för att lagra data och instruKtioner. 

Vi har följande avsnitt ur ett assembler program (4p) 


Rad 1: Tnovia. r8, 0xBEB4 
Rad 2: idw, rIO, 0( r8 ) 

Rad 3: ddw rll, 10(r8) 

Rad 4: Tdw, r12, 16(r8) 

Rad 5: Vtw r13 , 4(r8) 

Rad 6: TdvO^rU , 12(r8) 

Rad 7: stw ^r15, 8(r8) 

Vi har också ett cacheminne med egenskaper enligt tabell nedan: 


Storlek: 

512 byte 

Radlängd: 

16 byte 

Associativitet: 

2-vägs 

Adress längd 

16 bitar 


Förutsatt att cacheminnet är tomt från början, För varje instruktion som läser eller skriver till 
minnet ska du ange om det blir en träff eller miss i cacheminnet. Du kan också anta att 
instruktionerna sker sekventiellt och att data som läggs till i en uppgift finns kvar till nästa. 

OBS: ofullständigt svar kan INTE ge poäng dvs tabeller och beräkningar som 
används för att nå svaret ska också finns i lösningen. 






